package com.example.utils;

import com.example.domain.JdContent;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
import org.springframework.stereotype.Component;

import java.io.IOException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

/**
 * @author zhy
 * @date 2020/08/17 0017 19:06
 */
@Component
public class HtmlParseUtil {

//    public static void main(String[] args) throws IOException {
//        new HtmlParseUtil().parseJD("java").forEach(System.out::println);
//    }

    public List<JdContent> parseJD(String keyword) throws IOException {
        // 获得请求 不能获取到ajax的数据
        String url = "https://search.jd.com/Search?keyword=" + keyword;
        // 解析网页
        Document document = Jsoup.parse(new URL(url), 30000);
        //  所有js中可以使用的方法，这里都可以用
        Element element = document.getElementById("J_goodsList");
        // 获取所有的li元素
        Elements tags = element.getElementsByTag("li");

        List<JdContent> list = new ArrayList<>();

        for (Element tag : tags) {
            JdContent jdContent = new JdContent();

            String image = tag.getElementsByTag("img").eq(0).attr("src");//source-data-lazy-img
            String price = tag.getElementsByClass("p-price").eq(0).text();
            String title = tag.getElementsByClass("p-name").eq(0).text();

            jdContent.setImage(image);
            jdContent.setPrice(price);
            jdContent.setTitle(title);

            list.add(jdContent);
        }

        return list;
    }
}
